package com.yize.leetcode;

import org.junit.Test;

import java.util.LinkedList;
import java.util.Queue;

/**
 * 225. 用队列实现栈
 * 使用队列实现栈的下列操作：
 *
 * push(x) -- 元素 x 入栈
 * pop() -- 移除栈顶元素
 * top() -- 获取栈顶元素
 * empty() -- 返回栈是否为空
 * 注意:
 *
 * 你只能使用队列的基本操作-- 也就是 push to back, peek/pop from front, size, 和 is empty 这些操作是合法的。
 * 你所使用的语言也许不支持队列。 你可以使用 list 或者 deque（双端队列）来模拟一个队列 , 只要是标准的队列操作即可。
 * 你可以假设所有操作都是有效的（例如, 对一个空的栈不会调用 pop 或者 top 操作）。
 * 通过次数38,993提交次数60,975
 */
public class L225 {
    @Test
    public void test(){
        Queue<Integer> queue=new LinkedList<>();

    }
    class MyStack {

        private Queue<Integer> inputQueue;
        private Queue<Integer> outputQueue;

        /** Initialize your data structure here. */
        public MyStack() {
            inputQueue=new LinkedList<Integer>();
            outputQueue=new LinkedList<Integer>();
        }

        /** Push element x onto stack. */
        public void push(int x) {
            inputQueue.offer(x);
            while(outputQueue.isEmpty()==false){
                inputQueue.offer(outputQueue.poll());
            }
            Queue temp=inputQueue;
            inputQueue=outputQueue;
            outputQueue=temp;

        }

        /** Removes the element on top of the stack and returns that element. */
        public int pop() {
            return outputQueue.poll();
        }

        /** Get the top element. */
        public int top() {
            return outputQueue.peek();
        }

        /** Returns whether the stack is empty. */
        public boolean empty() {
            return outputQueue.isEmpty();
        }
    }

}
